home *** CD-ROM | disk | FTP | other *** search
/ Language/OS - Multiplatform Resource Library / LANGUAGE OS.iso / lisp / wgdb-42.lha / wgdb-4.2 / include / bfd.h < prev    next >
C/C++ Source or Header  |  1992-09-11  |  57KB  |  2,308 lines

  1. /* A -*- C -*- header file for the bfd library
  2.    Copyright 1990, 1991 Free Software Foundation, Inc.
  3.    Contributed by Cygnus Support.
  4.  
  5. This file is part of BFD, the Binary File Descriptor library.
  6.  
  7. This program is free software; you can redistribute it and/or modify
  8. it under the terms of the GNU General Public License as published by
  9. the Free Software Foundation; either version 2 of the License, or
  10. (at your option) any later version.
  11.  
  12. This program is distributed in the hope that it will be useful,
  13. but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  15. GNU General Public License for more details.
  16.  
  17. You should have received a copy of the GNU General Public License
  18. along with this program; if not, write to the Free Software
  19. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  */
  20.  
  21. /* bfd.h -- The only header file required by users of the bfd library 
  22.  
  23. This file is generated from various .c files, if you change it, your
  24. bits may be lost.
  25.  
  26. All the prototypes and definitions following the comment "THE FOLLOWING
  27. IS EXTRACTED FROM THE SOURCE" are extracted from the source files for
  28. BFD.  If you change it, someone oneday will extract it from the source
  29. again, and your changes will be lost.  To save yourself from this bind,
  30. change the definitions in the source in the bfd directory.  Type "make
  31. docs" and then "make headers" in that directory, and magically this file
  32. will change to reflect your changes.
  33.  
  34. If you don't have the tools to perform the extraction, then you are
  35. safe from someone on your system trampling over your header files.
  36. You should still maintain the equivalence between the source and this
  37. file though; every change you make to the .c file should be reflected
  38. here.  */
  39.  
  40. #ifndef __BFD_H_SEEN__
  41. #define __BFD_H_SEEN__
  42.  
  43. #include "ansidecl.h"
  44. #include "obstack.h"
  45.  
  46. /* Make it easier to declare prototypes (puts conditional here) */
  47. #ifndef PROTO
  48. #    if __STDC__
  49. #        define PROTO(type, name, arglist) type name arglist
  50. #    else
  51. #        define PROTO(type, name, arglist) type name ()
  52. #    endif
  53. #endif
  54.  
  55. #define BFD_VERSION "0.18"
  56.  
  57. /* forward declaration */
  58. typedef struct _bfd bfd;
  59.  
  60. /* General rules: functions which are boolean return true on success
  61.    and false on failure (unless they're a predicate).   -- bfd.doc */
  62. /* I'm sure this is going to break something and someone is going to
  63.    force me to change it. */
  64. /* typedef enum boolean {false, true} boolean; */
  65. /* Yup, SVR4 has a "typedef enum boolean" in <sys/types.h>  -fnf */
  66. typedef enum bfd_boolean {false, true} boolean;
  67.  
  68. /* Try to avoid breaking stuff */
  69. typedef  long int file_ptr;
  70.  
  71. /* Support for different sizes of target format ints and addresses */
  72.  
  73. #ifdef    HOST_64_BIT
  74. typedef HOST_64_BIT rawdata_offset;
  75. typedef HOST_64_BIT bfd_vma;
  76. typedef HOST_64_BIT bfd_word;
  77. typedef HOST_64_BIT bfd_offset;
  78. typedef HOST_64_BIT bfd_size_type;
  79. typedef HOST_64_BIT symvalue;
  80. typedef HOST_64_BIT bfd_64_type;
  81. #define fprintf_vma(s,x) \
  82.         fprintf(s,"%08x%08x", uint64_typeHIGH(x), uint64_typeLOW(x))
  83. #define printf_vma(x) \
  84.         printf(   "%08x%08x", uint64_typeHIGH(x), uint64_typeLOW(x))
  85. #else
  86. typedef struct {int a,b;} bfd_64_type;
  87. typedef unsigned long rawdata_offset;
  88. typedef unsigned long bfd_vma;
  89. typedef unsigned long bfd_offset;
  90. typedef unsigned long bfd_word;
  91. typedef unsigned long bfd_size;
  92. typedef unsigned long symvalue;
  93. typedef unsigned long bfd_size_type;
  94. #define printf_vma(x)     printf(    "%08lx", x)
  95. #define fprintf_vma(s,x) fprintf(s, "%08lx", x)
  96. #endif
  97.  
  98. typedef unsigned int flagword;    /* 32 bits of flags */
  99.  
  100. /** File formats */
  101.  
  102. typedef enum bfd_format {
  103.           bfd_unknown = 0,    /* file format is unknown */
  104.           bfd_object,    /* linker/assember/compiler output */
  105.           bfd_archive,    /* object archive file */
  106.           bfd_core,        /* core dump */
  107.           bfd_type_end}    /* marks the end; don't use it! */
  108.          bfd_format;
  109.  
  110. /* Object file flag values */
  111. #define NO_FLAGS    0
  112. #define HAS_RELOC   001
  113. #define EXEC_P      002
  114. #define HAS_LINENO  004
  115. #define HAS_DEBUG   010
  116. #define HAS_SYMS    020
  117. #define HAS_LOCALS  040
  118. #define DYNAMIC     0100
  119. #define WP_TEXT     0200
  120. #define D_PAGED     0400
  121.  
  122.  
  123. /* symbols and relocation */
  124.  
  125. typedef unsigned long symindex;
  126.  
  127. #define BFD_NO_MORE_SYMBOLS ((symindex) ~0)
  128.  
  129. typedef enum bfd_symclass {
  130.           bfd_symclass_unknown = 0,
  131.           bfd_symclass_fcommon, /* fortran common symbols */
  132.           bfd_symclass_global, /* global symbol, what a surprise */
  133.           bfd_symclass_debugger, /* some debugger symbol */
  134.           bfd_symclass_undefined /* none known */
  135.         } symclass;
  136.  
  137.  
  138. typedef int symtype;        /* Who knows, yet? */
  139.  
  140.  
  141. /* general purpose part of a symbol;
  142.    target specific parts will be found in libcoff.h, liba.out.h etc */
  143.  
  144.  
  145. #define bfd_get_section(x) ((x)->section)
  146. #define bfd_get_output_section(x) ((x)->section->output_section)
  147. #define bfd_set_section(x,y) ((x)->section) = (y)
  148. #define bfd_asymbol_base(x) ((x)->section?((x)->section->vma):0)
  149. #define bfd_asymbol_value(x) (bfd_asymbol_base(x) + x->value)
  150. #define bfd_asymbol_name(x) ((x)->name)
  151.  
  152. /* This is a type pun with struct ranlib on purpose! */
  153. typedef struct carsym {
  154.   char *name;
  155.   file_ptr file_offset;        /* look here to find the file */
  156. } carsym;            /* to make these you call a carsymogen */
  157.  
  158.   
  159. /* Used in generating armaps.  Perhaps just a forward definition would do? */
  160. struct orl {            /* output ranlib */
  161.   char **name;            /* symbol name */ 
  162.   file_ptr pos;            /* bfd* or file position */
  163.   int namidx;            /* index into string table */
  164. };
  165.  
  166.  
  167.  
  168. /* Linenumber stuff */
  169. typedef struct lineno_cache_entry {
  170.   unsigned int line_number;    /* Linenumber from start of function*/  
  171.   union {
  172.  struct symbol_cache_entry *sym;        /* Function name */
  173.     unsigned long offset;    /* Offset into section */
  174.   } u;
  175. } alent;
  176.  
  177. /* object and core file sections */
  178.  
  179.  
  180. #define    align_power(addr, align)    \
  181.     ( ((addr) + ((1<<(align))-1)) & (-1 << (align)))
  182.  
  183. typedef struct sec *sec_ptr;
  184.  
  185. #define bfd_section_name(bfd, ptr) ((ptr)->name)
  186. #define bfd_section_size(bfd, ptr) ((ptr)->size)
  187. #define bfd_section_vma(bfd, ptr) ((ptr)->vma)
  188. #define bfd_section_alignment(bfd, ptr) ((ptr)->alignment_power)
  189. #define bfd_get_section_flags(bfd, ptr) ((ptr)->flags)
  190. #define bfd_get_section_userdata(bfd, ptr) ((ptr)->userdata)
  191.  
  192. #define bfd_set_section_vma(bfd, ptr, val) (((ptr)->vma = (val)), true)
  193. #define bfd_set_section_alignment(bfd, ptr, val) (((ptr)->alignment_power = (val)),true)
  194. #define bfd_set_section_userdata(bfd, ptr, val) (((ptr)->userdata = (val)),true)
  195.  
  196. typedef struct stat stat_type; 
  197.  
  198. /** Error handling */
  199.  
  200. typedef enum bfd_error {
  201.           no_error = 0, system_call_error, invalid_target,
  202.           wrong_format, invalid_operation, no_memory,
  203.           no_symbols, no_relocation_info,
  204.           no_more_archived_files, malformed_archive,
  205.           symbol_not_found, file_not_recognized,
  206.           file_ambiguously_recognized, no_contents,
  207.         bfd_error_nonrepresentable_section,
  208.           invalid_error_code} bfd_ec;
  209.  
  210. extern bfd_ec bfd_error;
  211.  
  212. typedef struct bfd_error_vector {
  213.   PROTO(void,(* nonrepresentable_section ),(CONST bfd  *CONST abfd,
  214.                         CONST char *CONST name));
  215. } bfd_error_vector_type;
  216.  
  217. PROTO (char *, bfd_errmsg, ());
  218. PROTO (void, bfd_perror, (CONST char *message));
  219.  
  220.  
  221. typedef enum bfd_print_symbol
  222.   bfd_print_symbol_name,
  223.   bfd_print_symbol_more,
  224.   bfd_print_symbol_all
  225. } bfd_print_symbol_type;
  226.     
  227.  
  228.  
  229. /* The code that implements targets can initialize a jump table with this
  230.    macro.  It must name all its routines the same way (a prefix plus
  231.    the standard routine suffix), or it must #define the routines that
  232.    are not so named, before calling JUMP_TABLE in the initializer.  */
  233.  
  234. /* Semi-portable string concatenation in cpp */
  235. #ifndef CAT
  236. #ifdef __STDC__
  237. #define CAT(a,b) a##b
  238. #else
  239. #define CAT(a,b) a/**/b
  240. #endif
  241. #endif
  242.  
  243. #define JUMP_TABLE(NAME)\
  244. CAT(NAME,_core_file_failing_command),\
  245. CAT(NAME,_core_file_failing_signal),\
  246. CAT(NAME,_core_file_matches_executable_p),\
  247. CAT(NAME,_slurp_armap),\
  248. CAT(NAME,_slurp_extended_name_table),\
  249. CAT(NAME,_truncate_arname),\
  250. CAT(NAME,_write_armap),\
  251. CAT(NAME,_close_and_cleanup),    \
  252. CAT(NAME,_set_section_contents),\
  253. CAT(NAME,_get_section_contents),\
  254. CAT(NAME,_new_section_hook),\
  255. CAT(NAME,_get_symtab_upper_bound),\
  256. CAT(NAME,_get_symtab),\
  257. CAT(NAME,_get_reloc_upper_bound),\
  258. CAT(NAME,_canonicalize_reloc),\
  259. CAT(NAME,_make_empty_symbol),\
  260. CAT(NAME,_print_symbol),\
  261. CAT(NAME,_get_lineno),\
  262. CAT(NAME,_set_arch_mach),\
  263. CAT(NAME,_openr_next_archived_file),\
  264. CAT(NAME,_find_nearest_line),\
  265. CAT(NAME,_generic_stat_arch_elt),\
  266. CAT(NAME,_sizeof_headers),\
  267. CAT(NAME,_bfd_debug_info_start),\
  268. CAT(NAME,_bfd_debug_info_end),\
  269. CAT(NAME,_bfd_debug_info_accumulate)
  270.  
  271. #define COFF_SWAP_TABLE \
  272.  coff_swap_aux_in, coff_swap_sym_in, coff_swap_lineno_in, \
  273.  coff_swap_aux_out, coff_swap_sym_out, \
  274.  coff_swap_lineno_out, coff_swap_reloc_out, \
  275.  coff_swap_filehdr_out, coff_swap_aouthdr_out, \
  276.  coff_swap_scnhdr_out
  277.  
  278.  
  279.  
  280. /* User program access to BFD facilities */
  281.  
  282. extern CONST short _bfd_host_big_endian;
  283. #define HOST_BYTE_ORDER_BIG_P    (*(char *)&_bfd_host_big_endian)
  284.  
  285. /* The bfd itself */
  286.  
  287. /* Cast from const char * to char * so that caller can assign to
  288.    a char * without a warning.  */
  289. #define bfd_get_filename(abfd) ((char *) (abfd)->filename)
  290. #define bfd_get_format(abfd) ((abfd)->format)
  291. #define bfd_get_target(abfd) ((abfd)->xvec->name)
  292. #define bfd_get_file_flags(abfd) ((abfd)->flags)
  293. #define bfd_applicable_file_flags(abfd) ((abfd)->xvec->object_flags)
  294. #define bfd_applicable_section_flags(abfd) ((abfd)->xvec->section_flags)
  295. #define bfd_my_archive(abfd) ((abfd)->my_archive);
  296. #define bfd_has_map(abfd) ((abfd)->has_armap)
  297. #define bfd_header_twiddle_required(abfd) \
  298.         ((((abfd)->xvec->header_byteorder_big_p)        \
  299.       != (boolean)HOST_BYTE_ORDER_BIG_P) ? true:false)
  300.  
  301. #define bfd_valid_reloc_types(abfd) ((abfd)->xvec->valid_reloc_types)
  302. #define bfd_usrdata(abfd) ((abfd)->usrdata)
  303.  
  304. #define bfd_get_start_address(abfd) ((abfd)->start_address)
  305. #define bfd_get_symcount(abfd) ((abfd)->symcount)
  306. #define bfd_get_outsymbols(abfd) ((abfd)->outsymbols)
  307. #define bfd_count_sections(abfd) ((abfd)->section_count)
  308. #define bfd_get_architecture(abfd) ((abfd)->obj_arch)
  309. #define bfd_get_machine(abfd) ((abfd)->obj_machine)
  310.  
  311.  
  312.  
  313. #define BYTE_SIZE 1
  314. #define SHORT_SIZE 2
  315. #define LONG_SIZE 4
  316.  
  317.  
  318.  
  319. /*THE FOLLOWING IS EXTRACTED FROM THE SOURCE */
  320.  
  321.  
  322. /*:init.c*/
  323. /* bfd_init
  324.  
  325. This routine must be called before any other bfd function to initialize
  326. magical internal data structures.
  327. */
  328.  
  329.  void EXFUN(bfd_init,(void));
  330.  
  331. /*
  332. */
  333.  
  334. /*:opncls.c*/
  335. /* *i bfd_openr
  336. Opens the file supplied (using @code{fopen}) with the target supplied, it
  337. returns a pointer to the created BFD.
  338.  
  339. If NULL is returned then an error has occured.
  340. Possible errors are no_memory, invalid_target or system_call error.
  341. */
  342.  PROTO(bfd*, bfd_openr, (CONST char *filename,CONST char*target));
  343.  
  344. /*
  345.  
  346. *i bfd_fdopenr
  347. bfd_fdopenr is to bfd_fopenr much like  fdopen is to fopen. It opens a BFD on
  348. a file already described by the @var{fd} supplied. 
  349.  
  350. Possible errors are no_memory, invalid_target and system_call error.
  351. */
  352.   PROTO(bfd *, bfd_fdopenr,
  353.     (CONST char *filename, CONST char *target, int fd));
  354.  
  355. /*
  356.  
  357.  bfd_openw
  358. Creates a BFD, associated with file @var{filename}, using the file
  359. format @var{target}, and returns a pointer to it.
  360.  
  361. Possible errors are system_call_error, no_memory, invalid_target.
  362. */
  363.  PROTO(bfd *, bfd_openw, (CONST char *filename, CONST char *target));
  364.  
  365. /*
  366.  
  367.  bfd_close
  368. This function closes a BFD. If the BFD was open for writing, then
  369. pending operations are completed and the file written out and closed.
  370. If the created file is executable, then @code{chmod} is called to mark
  371. it as such.
  372.  
  373. All memory attached to the BFD's obstacks is released. 
  374.  
  375. @code{true} is returned if all is ok, otherwise @code{false}.
  376. */
  377.  PROTO(boolean, bfd_close,(bfd *));
  378.  
  379. /*
  380.  
  381.  bfd_create
  382. This routine creates a new BFD in the manner of @code{bfd_openw}, but without
  383. opening a file. The new BFD takes the target from the target used by
  384. @var{template}. The format is always set to @code{bfd_object}.
  385. */
  386.  
  387.  PROTO(bfd *, bfd_create, (CONST char *filename, bfd *template));
  388.  
  389. /*
  390.  
  391.  bfd_alloc_size
  392. Return the number of bytes in the obstacks connected to the supplied
  393. BFD.
  394. */
  395.  PROTO(bfd_size_type,bfd_alloc_size,(bfd *abfd));
  396.  
  397. /*
  398. */
  399.  
  400.  
  401. /*:libbfd.c*/
  402. /* *i bfd_put_size
  403. *i bfd_get_size
  404. These macros as used for reading and writing raw data in sections;
  405. each access (except for bytes) is vectored through the target format
  406. of the BFD and mangled accordingly. The mangling performs any
  407. necessary endian translations and removes alignment restrictions.
  408. */
  409. #define bfd_put_8(abfd, val, ptr) \
  410.                 (*((char *)ptr) = (char)val)
  411. #define bfd_get_8(abfd, ptr) \
  412.                 (*((char *)ptr))
  413. #define bfd_put_16(abfd, val, ptr) \
  414.                 BFD_SEND(abfd, bfd_putx16, (val,ptr))
  415. #define bfd_get_16(abfd, ptr) \
  416.                 BFD_SEND(abfd, bfd_getx16, (ptr))
  417. #define bfd_put_32(abfd, val, ptr) \
  418.                 BFD_SEND(abfd, bfd_putx32, (val,ptr))
  419. #define bfd_get_32(abfd, ptr) \
  420.                 BFD_SEND(abfd, bfd_getx32, (ptr))
  421. #define bfd_put_64(abfd, val, ptr) \
  422.                 BFD_SEND(abfd, bfd_putx64, (val, ptr))
  423. #define bfd_get_64(abfd, ptr) \
  424.                 BFD_SEND(abfd, bfd_getx64, (ptr))
  425. /* *i bfd_h_put_size
  426. *i bfd_h_get_size
  427. These macros have the same function as their @code{bfd_get_x}
  428. bretherin, except that they are used for removing information for the
  429. header records of object files. Believe it or not, some object files
  430. keep their header records in big endian order, and their data in little
  431. endan order.
  432. */
  433. #define bfd_h_put_8(abfd, val, ptr) \
  434.                 (*((char *)ptr) = (char)val)
  435. #define bfd_h_get_8(abfd, ptr) \
  436.                 (*((char *)ptr))
  437. #define bfd_h_put_16(abfd, val, ptr) \
  438.                 BFD_SEND(abfd, bfd_h_putx16,(val,ptr))
  439. #define bfd_h_get_16(abfd, ptr) \
  440.                 BFD_SEND(abfd, bfd_h_getx16,(ptr))
  441. #define bfd_h_put_32(abfd, val, ptr) \
  442.                 BFD_SEND(abfd, bfd_h_putx32,(val,ptr))
  443. #define bfd_h_get_32(abfd, ptr) \
  444.                 BFD_SEND(abfd, bfd_h_getx32,(ptr))
  445. #define bfd_h_put_64(abfd, val, ptr) \
  446.                 BFD_SEND(abfd, bfd_h_putx64,(val, ptr))
  447. #define bfd_h_get_64(abfd, ptr) \
  448.                 BFD_SEND(abfd, bfd_h_getx64,(ptr))
  449.  
  450. /*:section.c*/
  451. /* The shape of a section struct:
  452. */
  453.  
  454. typedef struct sec {
  455.  
  456. /*
  457. The name of the section, the name isn't a copy, the pointer is
  458. the same as that passed to bfd_make_section.
  459. */
  460.  
  461.     CONST char *name;
  462.  
  463. /*
  464. The next section in the list belonging to the BFD, or NULL.
  465. */
  466.  
  467.     struct sec *next;
  468.  
  469. /*
  470. The field flags contains attributes of the section. Some of these
  471. flags are read in from the object file, and some are synthesized from
  472. other information. 
  473. */
  474.  
  475. flagword flags;
  476.  
  477. /*
  478. */
  479.  
  480. #define SEC_NO_FLAGS   0x000
  481.  
  482. /*
  483. Tells the OS to allocate space for this section when loaded.
  484. This would clear for a section containing debug information only.
  485. */
  486.  
  487. #define SEC_ALLOC      0x001
  488.  
  489. /*
  490. Tells the OS to load the section from the file when loading.
  491. This would be clear for a .bss section 
  492. */
  493.  
  494. #define SEC_LOAD       0x002
  495.  
  496. /*
  497. The section contains data still to be relocated, so there will be some
  498. relocation information too.
  499. */
  500.  
  501. #define SEC_RELOC      0x004
  502.  
  503. /*
  504. Obsolete ? 
  505. */
  506.  
  507. #define SEC_BALIGN     0x008
  508.  
  509. /*
  510. A signal to the OS that the section contains read only data.
  511. */
  512.  
  513. #define SEC_READONLY   0x010
  514.  
  515. /*
  516. The section contains code only.
  517. */
  518.  
  519. #define SEC_CODE       0x020
  520.  
  521. /*
  522. The section contains data only.
  523. */
  524.  
  525. #define SEC_DATA        0x040
  526.  
  527. /*
  528. The section will reside in ROM.
  529. */
  530.  
  531. #define SEC_ROM        0x080
  532.  
  533. /*
  534. The section contains constructor information. This section type is
  535. used by the linker to create lists of constructors and destructors
  536. used by @code{g++}. When a back end sees a symbol which should be used
  537. in a constructor list, it creates a new section for the type of name
  538. (eg @code{__CTOR_LIST__}), attaches the symbol to it and builds a
  539. relocation. To build the lists of constructors, all the linker has to
  540. to is catenate all the sections called @code{__CTOR_LIST__} and
  541. relocte the data contained within - exactly the operations it would
  542. peform on standard data.
  543. */
  544.  
  545. #define SEC_CONSTRUCTOR 0x100
  546.  
  547. /*
  548. The section is a constuctor, and should be placed at the end of the ..
  549. */
  550.  
  551. #define SEC_CONSTRUCTOR_TEXT 0x1100
  552.  
  553. /*
  554. */
  555. #define SEC_CONSTRUCTOR_DATA 0x2100
  556.  
  557. /*
  558. */
  559. #define SEC_CONSTRUCTOR_BSS  0x3100
  560.  
  561. /*
  562.  
  563. The section has contents - a bss section could be
  564. @code{SEC_ALLOC} | @code{SEC_HAS_CONTENTS}, a debug section could be
  565. @code{SEC_HAS_CONTENTS}
  566. */
  567.  
  568. #define SEC_HAS_CONTENTS 0x200
  569.  
  570. /*
  571. An instruction to the linker not to output sections containing
  572. this flag even if they have information which would normally be written.
  573. */
  574.  
  575. #define SEC_NEVER_LOAD 0x400
  576.  
  577. /*
  578.  
  579. The base address of the section in the address space of the target.
  580. */
  581.  
  582.    bfd_vma vma;
  583.  
  584. /*
  585. The size of the section in bytes of the loaded section. This contains
  586. a value even if the section has no contents (eg, the size of @code{.bss}).
  587. */
  588.  
  589.    bfd_size_type size;    
  590.  
  591. /*
  592. If this section is going to be output, then this value is the
  593. offset into the output section of the first byte in the input
  594. section. Eg, if this was going to start at the 100th byte in the
  595. output section, this value would be 100. 
  596. */
  597.  
  598.    bfd_vma output_offset;
  599.  
  600. /*
  601. The output section through which to map on output.
  602. */
  603.  
  604.    struct sec *output_section;
  605.  
  606. /*
  607. The alignment requirement of the section, as an exponent - eg 3
  608. aligns to 2^3 (or 8) 
  609. */
  610.  
  611.    unsigned int alignment_power;
  612.  
  613. /*
  614. If an input section, a pointer to a vector of relocation records for
  615. the data in this section.
  616. */
  617.  
  618.    struct reloc_cache_entry *relocation;
  619.  
  620. /*
  621. If an output section, a pointer to a vector of pointers to
  622. relocation records for the data in this section.
  623. */
  624.  
  625.    struct reloc_cache_entry **orelocation;
  626.  
  627. /*
  628. The number of relocation records in one of the above 
  629. */
  630.  
  631.    unsigned reloc_count;
  632.  
  633. /*
  634. Which section is it 0..nth     
  635. */
  636.  
  637.    int index;                      
  638.  
  639. /*
  640. Information below is back end specific - and not always used or
  641. updated 
  642.  
  643. File position of section data   
  644. */
  645.  
  646.    file_ptr filepos;      
  647. /* File position of relocation info        
  648. */
  649.  
  650.    file_ptr rel_filepos;
  651.  
  652. /*
  653. File position of line data              
  654. */
  655.  
  656.    file_ptr line_filepos;
  657.  
  658. /*
  659. Pointer to data for applications        
  660. */
  661.  
  662.    PTR userdata;
  663.  
  664. /*
  665. */
  666.    struct lang_output_section *otheruserdata;
  667.  
  668. /*
  669. Attached line number information        
  670. */
  671.  
  672.    alent *lineno;
  673. /* Number of line number records   
  674. */
  675.  
  676.    unsigned int lineno_count;
  677.  
  678. /*
  679. When a section is being output, this value changes as more
  680. linenumbers are written out 
  681. */
  682.  
  683.    file_ptr moving_line_filepos;
  684.  
  685. /*
  686. what the section number is in the target world 
  687. */
  688.  
  689.    unsigned int target_index;
  690.  
  691. /*
  692. */
  693.    PTR used_by_bfd;
  694.  
  695. /*
  696. If this is a constructor section then here is a list of the
  697. relocations created to relocate items within it.
  698. */
  699.  
  700.    struct relent_chain *constructor_chain;
  701.  
  702. /*
  703. The BFD which owns the section.
  704. */
  705.  
  706.    bfd *owner;
  707.  
  708. /*
  709. */
  710. } asection ;
  711.  
  712. /*
  713.  
  714.  bfd_get_section_by_name
  715. Runs through the provided @var{abfd} and returns the @code{asection}
  716. who's name matches that provided, otherwise NULL. @xref{Sections}, for more information.
  717. */
  718.  
  719.  PROTO(asection *, bfd_get_section_by_name,
  720.     (bfd *abfd, CONST char *name));
  721.  
  722. /*
  723.  
  724.  bfd_make_section
  725. This function creates a new empty section called @var{name} and attaches it
  726. to the end of the chain of sections for the BFD supplied. An attempt to
  727. create a section with a name which is already in use, returns the old
  728. section by that name instead.
  729.  
  730. Possible errors are:
  731. @table @code
  732. @item invalid_operation
  733. If output has already started for this BFD.
  734. @item no_memory
  735. If obstack alloc fails.
  736. @end table
  737. */
  738.  
  739.  PROTO(asection *, bfd_make_section, (bfd *, CONST char *name));
  740.  
  741. /*
  742.  
  743.  bfd_set_section_flags
  744. Attempts to set the attributes of the section named in the BFD
  745. supplied to the value. Returns true on success, false on error.
  746. Possible error returns are:
  747. @table @code
  748. @item invalid operation
  749. The section cannot have one or more of the attributes requested. For
  750. example, a .bss section in @code{a.out} may not have the
  751. @code{SEC_HAS_CONTENTS} field set.
  752. @end table
  753. */
  754.  
  755.  PROTO(boolean, bfd_set_section_flags,
  756.        (bfd *, asection *, flagword));
  757.  
  758. /*
  759.  
  760.  bfd_map_over_sections
  761. Calls the provided function @var{func} for each section attached to
  762. the BFD @var{abfd}, passing @var{obj} as an argument. The function
  763. will be called as if by 
  764.  
  765. @example
  766.   func(abfd, the_section, obj);
  767. @end example
  768. */
  769.  
  770.  PROTO(void, bfd_map_over_sections,
  771.             (bfd *abfd, void (*func)(), PTR obj));
  772.  
  773. /*
  774.  
  775. This is the prefered method for iterating over sections, an
  776. alternative would be to use a loop:
  777.  
  778. @example
  779.    section *p;
  780.    for (p = abfd->sections; p != NULL; p = p->next)
  781.       func(abfd, p, ...)
  782. @end example
  783.  
  784.  bfd_set_section_size
  785. Sets @var{section} to the size @var{val}. If the operation is ok, then
  786. @code{true} is returned, else @code{false}. 
  787.  
  788. Possible error returns:
  789. @table @code
  790. @item invalid_operation
  791. Writing has started to the BFD, so setting the size is invalid
  792. @end table 
  793. */
  794.  
  795.  PROTO(boolean, bfd_set_section_size,
  796.      (bfd *, asection *, bfd_size_type val));
  797.  
  798. /*
  799.  
  800.  bfd_set_section_contents
  801. Sets the contents of the section @var{section} in BFD @var{abfd} to
  802. the data starting in memory at @var{data}. The data is written to the
  803. output section starting at offset @var{offset} for @var{count} bytes.
  804.  
  805. Normally @code{true} is returned, else @code{false}. Possible error
  806. returns are:
  807. @table @code
  808. @item no_contents
  809. The output section does not have the @code{SEC_HAS_CONTENTS}
  810. attribute, so nothing can be written to it.
  811. @item and some more too
  812. @end table
  813. This routine is front end to the back end function @code{_bfd_set_section_contents}.
  814. */
  815.  
  816.  PROTO(boolean, bfd_set_section_contents,
  817.          (bfd *abfd,        
  818.          asection *section,
  819.          PTR data,
  820.          file_ptr offset,
  821.          bfd_size_type count));
  822.  
  823. /*
  824.  
  825.  bfd_get_section_contents
  826. This function reads data from @var{section} in BFD @var{abfd} into
  827. memory starting at @var{location}. The data is read at an offset of
  828. @var{offset} from the start of the input section, and is read for
  829. @var{count} bytes.
  830.  
  831. If the contents of a constuctor with the @code{SEC_CONSTUCTOR} flag
  832. set are requested, then the @var{location} is filled with zeroes.
  833.  
  834. If no errors occur, @code{true} is returned, else @code{false}.
  835. Possible errors are:
  836.  
  837. @table @code
  838. @item unknown yet
  839. @end table
  840. */
  841.  
  842.  PROTO(boolean, bfd_get_section_contents, 
  843.         (bfd *abfd, asection *section, PTR location,
  844.          file_ptr offset, bfd_size_type count));
  845.  
  846. /*
  847. */
  848.  
  849.  
  850.  
  851. /*:archures.c*/
  852. /* bfd_architecture
  853. This enum gives the object file's CPU
  854. architecture, in a global sense.  E.g. what processor family does it
  855. belong to?  There is another field, which indicates what processor
  856. within the family is in use.  The machine gives a number which
  857. distingushes different versions of the architecture, containing for
  858. example 2 and 3 for Intel i960 KA and i960 KB, and 68020 and 68030 for
  859. Motorola 68020 and 68030.
  860. */
  861.  
  862. enum bfd_architecture 
  863. {
  864.   bfd_arch_unknown,   /* File arch not known */
  865.   bfd_arch_obscure,   /* Arch known, not one of these */
  866.   bfd_arch_m68k,      /* Motorola 68xxx */
  867.   bfd_arch_vax,       /* DEC Vax */   
  868.   bfd_arch_i960,      /* Intel 960 */
  869.     /* The order of the following is important.
  870.        lower number indicates a machine type that 
  871.        only accepts a subset of the instructions
  872.        available to machines with higher numbers.
  873.        The exception is the "ca", which is
  874.        incompatible with all other machines except 
  875.        "core". */
  876.  
  877. #define bfd_mach_i960_core      1
  878. #define bfd_mach_i960_ka_sa     2
  879. #define bfd_mach_i960_kb_sb     3
  880. #define bfd_mach_i960_mc        4
  881. #define bfd_mach_i960_xa        5
  882. #define bfd_mach_i960_ca        6
  883.  
  884.   bfd_arch_a29k,      /* AMD 29000 */
  885.   bfd_arch_sparc,     /* SPARC */
  886.   bfd_arch_mips,      /* MIPS Rxxxx */
  887.   bfd_arch_i386,      /* Intel 386 */
  888.   bfd_arch_ns32k,     /* National Semiconductor 32xxx */
  889.   bfd_arch_tahoe,     /* CCI/Harris Tahoe */
  890.   bfd_arch_i860,      /* Intel 860 */
  891.   bfd_arch_romp,      /* IBM ROMP RS/6000 */
  892.   bfd_arch_alliant,   /* Alliant */
  893.   bfd_arch_convex,    /* Convex */
  894.   bfd_arch_m88k,      /* Motorola 88xxx */
  895.   bfd_arch_pyramid,   /* Pyramid Technology */
  896.   bfd_arch_h8300,     /* Hitachi H8/300 */
  897.   bfd_arch_last
  898.   };
  899.  
  900. /*
  901. stuff
  902.  
  903.  bfd_arch_info
  904. This structure contains information on architectures.
  905. */
  906. typedef int bfd_reloc_code_type;
  907.  
  908. typedef struct bfd_arch_info 
  909. {
  910.   int bits_per_word;
  911.   int bits_per_address;
  912.   int bits_per_byte;
  913.   enum bfd_architecture arch;
  914.   long mach;
  915.   char *arch_name;
  916.   CONST  char *printable_name;
  917. /* true if this is the default machine for the architecture */
  918.   boolean the_default;    
  919.   CONST struct bfd_arch_info * EXFUN((*compatible),(CONST struct bfd_arch_info *a,
  920.                              CONST struct bfd_arch_info *b));
  921.  
  922.   boolean EXFUN((*scan),(CONST struct bfd_arch_info *,CONST char *));
  923.   unsigned int EXFUN((*disassemble),(bfd_vma addr, CONST char *data,
  924.                      PTR stream));
  925.   CONST struct reloc_howto_struct *EXFUN((*reloc_type_lookup), (CONST struct
  926.                                 bfd_arch_info *,
  927.                                 bfd_reloc_code_type  code));
  928.  
  929.   struct bfd_arch_info *next;
  930.  
  931. } bfd_arch_info_type;
  932.  
  933. /*
  934.  bfd_printable_name
  935.  
  936. Return a printable string representing the architecture and machine
  937. from the pointer to the arch info structure 
  938. */
  939.  
  940.  CONST char *EXFUN(bfd_printable_name,(bfd *abfd));
  941.  
  942. /*
  943.  
  944. *i bfd_scan_arch
  945. This routine is provided with a string and tries to work out if bfd
  946. supports any cpu which could be described with the name provided.  The
  947. routine returns a pointer to an arch_info structure if a machine is
  948. found, otherwise NULL.
  949. */
  950.  
  951.  bfd_arch_info_type *EXFUN(bfd_scan_arch,(CONST char *));
  952.  
  953. /*
  954.  
  955.  bfd_arch_get_compatible
  956. This routine is used to determine whether two BFDs' architectures and
  957. machine types are compatible.  It calculates the lowest common
  958. denominator between the two architectures and machine types implied by
  959. the BFDs and returns a pointer to an arch_info structure describing
  960. the compatible machine.
  961. */
  962.  
  963.  CONST bfd_arch_info_type *EXFUN(bfd_arch_get_compatible,
  964.      (CONST bfd *abfd,
  965.      CONST bfd *bbfd));
  966.  
  967. /*
  968.  
  969.  bfd_set_arch_info
  970. */
  971.  
  972.  void EXFUN(bfd_set_arch_info,(bfd *, bfd_arch_info_type *));
  973.  
  974. /*
  975.  
  976.  bfd_get_arch
  977.  
  978. Returns the enumerated type which describes the supplied bfd's
  979. architecture
  980. */
  981.  
  982.  enum bfd_architecture EXFUN(bfd_get_arch, (bfd *abfd));
  983.  
  984. /*
  985.  
  986.  bfd_get_mach
  987.  
  988. Returns the long type which describes the supplied bfd's
  989. machine
  990. */
  991.  
  992.  unsigned long EXFUN(bfd_get_mach, (bfd *abfd));
  993.  
  994. /*
  995.  
  996.  bfd_arch_bits_per_byte
  997.  
  998. Returns the number of bits in one of the architectures bytes
  999. */
  1000.  
  1001.  unsigned int EXFUN(bfd_arch_bits_per_byte, (bfd *abfd));
  1002.  
  1003. /*
  1004.  
  1005.  bfd_arch_bits_per_address
  1006.  
  1007. Returns the number of bits in one of the architectures addresses
  1008. */
  1009.  
  1010.  unsigned int EXFUN(bfd_arch_bits_per_address, (bfd *abfd));
  1011.  
  1012. /*
  1013.  
  1014.  bfd_get_arch_info
  1015. */
  1016.  
  1017.  bfd_arch_info_type * EXFUN(bfd_get_arch_info,(bfd *));
  1018.  
  1019. /*
  1020.  
  1021.  bfd_lookup_arch
  1022.  
  1023. */
  1024.  bfd_arch_info_type * EXFUN(bfd_lookup_arch,(enum
  1025.     bfd_architecture arch,long machine));
  1026.  
  1027. /*
  1028.  
  1029. Look for the architecure info struct which matches the arguments
  1030. given. A machine of 0 will match the machine/architecture structure which
  1031. marks itself as the default.
  1032.  
  1033.  bfd_printable_arch_mach
  1034. Return a printable string representing the architecture and machine
  1035. type. 
  1036.  
  1037. NB. The use of this routine is depreciated.
  1038. */
  1039.  
  1040.  PROTO(CONST char *,bfd_printable_arch_mach,
  1041.     (enum bfd_architecture arch, unsigned long machine));
  1042.  
  1043. /*
  1044. */
  1045.  
  1046. /*:reloc.c*/
  1047. /* bfd_perform_relocation
  1048. The relocation routine returns as a status an enumerated type:
  1049. */
  1050.  
  1051. typedef enum bfd_reloc_status {
  1052. /* No errors detected
  1053. */
  1054.  
  1055.   bfd_reloc_ok,
  1056.  
  1057. /*
  1058. The relocation was performed, but there was an overflow.
  1059. */
  1060.  
  1061.   bfd_reloc_overflow,
  1062.  
  1063. /*
  1064. The address to relocate was not within the section supplied
  1065. */
  1066.  
  1067.   bfd_reloc_outofrange,
  1068.  
  1069. /*
  1070. Used by special functions
  1071. */
  1072.  
  1073.   bfd_reloc_continue,
  1074.  
  1075. /*
  1076. Unused 
  1077. */
  1078.  
  1079.   bfd_reloc_notsupported,
  1080.  
  1081. /*
  1082. Unsupported relocation size requested. 
  1083. */
  1084.  
  1085.   bfd_reloc_other,
  1086.  
  1087. /*
  1088. The symbol to relocate against was undefined.
  1089. */
  1090.  
  1091.   bfd_reloc_undefined,
  1092.  
  1093. /*
  1094. The relocation was performed, but may not be ok - presently generated
  1095. only when linking i960 coff files with i960 b.out symbols.
  1096. */
  1097.  
  1098.   bfd_reloc_dangerous
  1099.    }
  1100.  bfd_reloc_status_type;
  1101.  
  1102. /*
  1103. */
  1104.  
  1105. typedef struct reloc_cache_entry 
  1106. {
  1107.  
  1108. /*
  1109. A pointer into the canonical table of pointers 
  1110. */
  1111.  
  1112.   struct symbol_cache_entry **sym_ptr_ptr;
  1113.  
  1114. /*
  1115. offset in section                 
  1116. */
  1117.  
  1118.   rawdata_offset address;
  1119.  
  1120. /*
  1121. addend for relocation value        
  1122. */
  1123.  
  1124.   bfd_vma addend;    
  1125.  
  1126. /*
  1127. if sym is null this is the section 
  1128. */
  1129.  
  1130.   struct sec *section;
  1131.  
  1132. /*
  1133. Pointer to how to perform the required relocation
  1134. */
  1135.  
  1136.   CONST struct reloc_howto_struct *howto;
  1137. } arelent;
  1138.  
  1139. /*
  1140.  
  1141.  reloc_howto_type
  1142. The @code{reloc_howto_type} is a structure which contains all the
  1143. information that BFD needs to know to tie up a back end's data.
  1144. */
  1145.  
  1146. typedef CONST struct reloc_howto_struct 
  1147. /* The type field has mainly a documetary use - the back end can to what
  1148. it wants with it, though the normally the back end's external idea of
  1149. what a reloc number would be would be stored in this field. For
  1150. example, the a PC relative word relocation in a coff environment would
  1151. have the type 023 - because that's what the outside world calls a
  1152. R_PCRWORD reloc.
  1153. */
  1154.  
  1155.   unsigned int type;
  1156.  
  1157. /*
  1158. The value the final relocation is shifted right by. This drops
  1159. unwanted data from the relocation. 
  1160. */
  1161.  
  1162.   unsigned int rightshift;
  1163.  
  1164. /*
  1165. The size of the item to be relocated - 0, is one byte, 1 is 2 bytes, 3
  1166. is four bytes.
  1167. */
  1168.  
  1169.   unsigned int size;
  1170.  
  1171. /*
  1172. Now obsolete
  1173. */
  1174.  
  1175.   unsigned int bitsize;
  1176.  
  1177. /*
  1178. Notes that the relocation is relative to the location in the data
  1179. section of the addend. The relocation function will subtract from the
  1180. relocation value the address of the location being relocated.
  1181. */
  1182.  
  1183.   boolean pc_relative;
  1184.  
  1185. /*
  1186. Now obsolete
  1187. */
  1188.  
  1189.   unsigned int bitpos;
  1190.  
  1191. /*
  1192. Now obsolete
  1193. */
  1194.  
  1195.   boolean absolute;
  1196.  
  1197. /*
  1198. Causes the relocation routine to return an error if overflow is
  1199. detected when relocating.
  1200. */
  1201.  
  1202.   boolean complain_on_overflow;
  1203.  
  1204. /*
  1205. If this field is non null, then the supplied function is called rather
  1206. than the normal function. This allows really strange relocation
  1207. methods to be accomodated (eg, i960 callj instructions).
  1208. */
  1209.  
  1210.   bfd_reloc_status_type (*special_function)();
  1211.  
  1212. /*
  1213. The textual name of the relocation type.
  1214. */
  1215.  
  1216.   char *name;
  1217.  
  1218. /*
  1219. When performing a partial link, some formats must modify the
  1220. relocations rather than the data - this flag signals this.
  1221. */
  1222.  
  1223.   boolean partial_inplace;
  1224.  
  1225. /*
  1226. The src_mask is used to select what parts of the read in data are to
  1227. be used in the relocation sum. Eg, if this was an 8 bit bit of data
  1228. which we read and relocated, this would be 0x000000ff. When we have
  1229. relocs which have an addend, such as sun4 extended relocs, the value
  1230. in the offset part of a relocating field is garbage so we never use
  1231. it. In this case the mask would be 0x00000000.
  1232. */
  1233.  
  1234.   bfd_word src_mask;
  1235. /* The dst_mask is what parts of the instruction are replaced into the
  1236. instruction. In most cases src_mask == dst_mask, except in the above
  1237. special case, where dst_mask would be 0x000000ff, and src_mask would
  1238. be 0x00000000.
  1239. */
  1240.  
  1241.   bfd_word dst_mask;           
  1242.  
  1243. /*
  1244. When some formats create PC relative instructions, they leave the
  1245. value of the pc of the place being relocated in the offset slot of the
  1246. instruction, so that a PC relative relocation can be made just by
  1247. adding in an ordinary offset (eg sun3 a.out). Some formats leave the
  1248. displacement part of an instruction empty (eg m88k bcs), this flag
  1249. signals the fact.
  1250. */
  1251.  
  1252.   boolean pcrel_offset;
  1253. } reloc_howto_type;
  1254.  
  1255. /*
  1256.  
  1257.  HOWTO
  1258. The HOWTO define is horrible and will go away.
  1259. */
  1260. #define HOWTO(C, R,S,B, P, BI, ABS, O, SF, NAME, INPLACE, MASKSRC, MASKDST, PC) \
  1261.   {(unsigned)C,R,S,B, P, BI, ABS,O,SF,NAME,INPLACE,MASKSRC,MASKDST,PC}
  1262.  
  1263. /*
  1264. And will be replaced with the totally magic way. But for the moment,
  1265. we are compatible, so do it this way..
  1266. */
  1267.  
  1268. #define NEWHOWTO( FUNCTION, NAME,SIZE,REL,IN) HOWTO(0,0,SIZE,0,REL,0,false,false,FUNCTION, NAME,false,0,0,IN)
  1269.  
  1270. /*
  1271. Helper routine to turn a symbol into a relocation value.
  1272. */
  1273.  
  1274.  
  1275. #define HOWTO_PREPARE(relocation, symbol)     \
  1276.   {                        \
  1277.   if (symbol != (asymbol *)NULL) {        \
  1278.     if (symbol->flags & BSF_FORT_COMM) {    \
  1279.       relocation = 0;                \
  1280.     }                        \
  1281.     else {                    \
  1282.       relocation = symbol->value;        \
  1283.     }                        \
  1284.   }                        \
  1285.   if (symbol->section != (asection *)NULL) {    \
  1286.     relocation += symbol->section->output_section->vma +    \
  1287.       symbol->section->output_offset;        \
  1288.   }                        \
  1289. }            
  1290.  
  1291. /*
  1292.  reloc_chain
  1293. */
  1294. typedef unsigned char bfd_byte;
  1295.  
  1296. typedef struct relent_chain {
  1297.   arelent relent;
  1298.   struct   relent_chain *next;
  1299. } arelent_chain;
  1300.  
  1301. /*
  1302.  
  1303. If an output_bfd is supplied to this function the generated image
  1304. will be relocatable, the relocations are copied to the output file
  1305. after they have been changed to reflect the new state of the world.
  1306. There are two ways of reflecting the results of partial linkage in an
  1307. output file; by modifying the output data in place, and by modifying
  1308. the relocation record. Some native formats (eg basic a.out and basic
  1309. coff) have no way of specifying an addend in the relocation type, so
  1310. the addend has to go in the output data.  This is no big deal since in
  1311. these formats the output data slot will always be big enough for the
  1312. addend. Complex reloc types with addends were invented to solve just
  1313. this problem.
  1314. */
  1315.  PROTO(bfd_reloc_status_type,
  1316.                 bfd_perform_relocation,
  1317.                         (bfd * abfd,
  1318.                         arelent *reloc_entry,
  1319.                         PTR data,
  1320.                         asection *input_section,
  1321.                         bfd *output_bfd));
  1322.  
  1323. /*
  1324.  
  1325.  bfd_reloc_code_type
  1326. */
  1327.  
  1328. typedef enum bfd_reloc_code_real {
  1329.  
  1330. /*
  1331. 16 bits wide, simple reloc 
  1332. */
  1333.  
  1334.   BFD_RELOC_16,    
  1335.  
  1336. /*
  1337. 8 bits wide, but used to form an address like 0xffnn
  1338. */
  1339.  
  1340.   BFD_RELOC_8_FFnn,
  1341.  
  1342. /*
  1343. 8 bits wide, simple
  1344. */
  1345.  
  1346.   BFD_RELOC_8,
  1347.  
  1348. /*
  1349. 8 bits wide, pc relative
  1350. */
  1351.  
  1352.   BFD_RELOC_8_PCREL
  1353.  } bfd_reloc_code_real_type;
  1354.  
  1355. /*
  1356.  
  1357.  bfd_reloc_type_lookup
  1358. This routine returns a pointer to a howto struct which when invoked,
  1359. will perform the supplied relocation on data from the architecture
  1360. noted.
  1361.  
  1362. [Note] This function will go away.
  1363. */
  1364.  
  1365.  PROTO(CONST struct reloc_howto_struct *,
  1366.     bfd_reloc_type_lookup,
  1367.     (CONST bfd_arch_info_type *arch, bfd_reloc_code_type code));
  1368.  
  1369. /*
  1370. */
  1371.  
  1372. /*:syms.c*/
  1373. /* @subsection typedef asymbol
  1374. An @code{asymbol} has the form:
  1375. */
  1376.  
  1377. typedef struct symbol_cache_entry 
  1378. {
  1379. /* A pointer to the BFD which owns the symbol. This information is
  1380. necessary so that a back end can work out what additional (invisible to
  1381. the application writer) information is carried with the symbol. 
  1382. */
  1383.  
  1384.   struct _bfd *the_bfd;
  1385.  
  1386. /*
  1387. The text of the symbol. The name is left alone, and not copied - the
  1388. application may not alter it. 
  1389. */
  1390.  
  1391.    CONST char *name;
  1392.  
  1393. /*
  1394. The value of the symbol.
  1395. */
  1396.  
  1397.    symvalue value;
  1398.  
  1399. /*
  1400. Attributes of a symbol:
  1401. */
  1402.  
  1403. #define BSF_NO_FLAGS    0x00
  1404.  
  1405. /*
  1406. The symbol has local scope; @code{static} in @code{C}. The value is
  1407. the offset into the section of the data.
  1408. */
  1409.  
  1410. #define BSF_LOCAL    0x01
  1411.  
  1412. /*
  1413. The symbol has global scope; initialized data in @code{C}. The value
  1414. is the offset into the section of the data.
  1415. */
  1416.  
  1417. #define BSF_GLOBAL    0x02
  1418.  
  1419. /*
  1420. Obsolete
  1421. */
  1422.  
  1423. #define BSF_IMPORT    0x04
  1424.  
  1425. /*
  1426. The symbol has global scope, and is exported. The value is the offset
  1427. into the section of the data.
  1428. */
  1429.  
  1430. #define BSF_EXPORT    0x08
  1431.  
  1432. /*
  1433. The symbol is undefined. @code{extern} in @code{C}. The value has no meaning.
  1434. */
  1435.  
  1436. #define BSF_UNDEFINED    0x10    
  1437.  
  1438. /*
  1439. The symbol is common, initialized to zero; default in @code{C}. The
  1440. value is the size of the object in bytes.
  1441. */
  1442.  
  1443. #define BSF_FORT_COMM    0x20    
  1444.  
  1445. /*
  1446. A normal @code{C} symbol would be one of:
  1447. @code{BSF_LOCAL}, @code{BSF_FORT_COMM},  @code{BSF_UNDEFINED} or @code{BSF_EXPORT|BSD_GLOBAL}
  1448.  
  1449. The symbol is a debugging record. The value has an arbitary meaning.
  1450. */
  1451.  
  1452. #define BSF_DEBUGGING    0x40
  1453.  
  1454. /*
  1455. The symbol has no section attached, any value is the actual value and
  1456. is not a relative offset to a section.
  1457. */
  1458.  
  1459. #define BSF_ABSOLUTE    0x80
  1460.  
  1461. /*
  1462. Used by the linker
  1463. */
  1464.  
  1465. #define BSF_KEEP        0x10000
  1466. #define BSF_KEEP_G      0x80000
  1467.  
  1468. /*
  1469. Unused
  1470. */
  1471.  
  1472. #define BSF_WEAK        0x100000
  1473. #define BSF_CTOR        0x200000 
  1474. #define BSF_FAKE        0x400000 
  1475.  
  1476. /*
  1477. The symbol used to be a common symbol, but now it is allocated.
  1478. */
  1479.  
  1480. #define BSF_OLD_COMMON  0x800000  
  1481.  
  1482. /*
  1483. The default value for common data.
  1484. */
  1485.  
  1486. #define BFD_FORT_COMM_DEFAULT_VALUE 0
  1487.  
  1488. /*
  1489. In some files the type of a symbol sometimes alters its location
  1490. in an output file - ie in coff a @code{ISFCN} symbol which is also @code{C_EXT}
  1491. symbol appears where it was declared and not at the end of a section. 
  1492. This bit is set by the target BFD part to convey this information. 
  1493. */
  1494.  
  1495. #define BSF_NOT_AT_END    0x40000
  1496.  
  1497. /*
  1498. Signal that the symbol is the label of constructor section.
  1499. */
  1500.  
  1501. #define BSF_CONSTRUCTOR   0x1000000
  1502.  
  1503. /*
  1504. Signal that the symbol is a warning symbol. If the symbol is a warning
  1505. symbol, then the value field (I know this is tacky) will point to the
  1506. asymbol which when referenced will cause the warning.
  1507. */
  1508.  
  1509. #define BSF_WARNING       0x2000000
  1510.  
  1511. /*
  1512. Signal that the symbol is indirect. The value of the symbol is a
  1513. pointer to an undefined asymbol which contains the name to use
  1514. instead.
  1515. */
  1516.  
  1517. #define BSF_INDIRECT     0x4000000
  1518.  
  1519. /*
  1520. */
  1521.   flagword flags;
  1522.  
  1523. /*
  1524. A pointer to the section to which this symbol is relative, or 0 if the
  1525. symbol is absolute or undefined. Note that it is not sufficient to set
  1526. this location to 0 to mark a symbol as absolute - the flag
  1527. @code{BSF_ABSOLUTE} must be set also.
  1528. */
  1529.  
  1530.   struct sec *section;
  1531.  
  1532. /*
  1533. Back end special data. This is being phased out in favour of making
  1534. this a union.
  1535. */
  1536.  
  1537.   PTR udata;    
  1538. } asymbol;
  1539.  
  1540. /*
  1541.  
  1542.  get_symtab_upper_bound
  1543. Returns the number of bytes required in a vector of pointers to
  1544. @code{asymbols} for all the symbols in the supplied BFD, including a
  1545. terminal NULL pointer. If there are no symbols in the BFD, then 0 is
  1546. returned.
  1547. */
  1548. #define get_symtab_upper_bound(abfd) \
  1549.      BFD_SEND (abfd, _get_symtab_upper_bound, (abfd))
  1550.  
  1551. /*
  1552.  
  1553.  bfd_canonicalize_symtab
  1554. Supplied a BFD and a pointer to an uninitialized vector of pointers.
  1555. This reads in the symbols from the BFD, and fills in the table with
  1556. pointers to the symbols, and a trailing NULL. The routine returns the
  1557. actual number of symbol pointers not including the NULL.
  1558. */
  1559.  
  1560. #define bfd_canonicalize_symtab(abfd, location) \
  1561.      BFD_SEND (abfd, _bfd_canonicalize_symtab,\
  1562.                   (abfd, location))
  1563.  
  1564. /*
  1565.  bfd_set_symtab
  1566. Provided a table of pointers to to symbols and a count, writes to the
  1567. output BFD the symbols when closed.
  1568. */
  1569.  
  1570.  PROTO(boolean, bfd_set_symtab, (bfd *, asymbol **, unsigned int ));
  1571.  
  1572. /*
  1573.  
  1574.  bfd_print_symbol_vandf
  1575. Prints the value and flags of the symbol supplied to the stream file.
  1576. */
  1577.  
  1578.  PROTO(void, bfd_print_symbol_vandf, (PTR file, asymbol *symbol));
  1579.  
  1580. /*
  1581.  
  1582.   bfd_make_empty_symbol
  1583. This function creates a new @code{asymbol} structure for the BFD, and
  1584. returns a pointer to it.
  1585.  
  1586. This routine is necessary, since each back end has private information
  1587. surrounding the @code{asymbol}. Building your own @code{asymbol} and
  1588. pointing to it will not create the private information, and will cause
  1589. problems later on.
  1590. */
  1591. #define bfd_make_empty_symbol(abfd) \
  1592.      BFD_SEND (abfd, _bfd_make_empty_symbol, (abfd))
  1593.  
  1594. /*:bfd.c*/
  1595. /* @section @code{typedef bfd}
  1596.  
  1597. A BFD is has type @code{bfd}; objects of this type are the cornerstone
  1598. of any application using @code{libbfd}. References though the BFD and
  1599. to data in the BFD give the entire BFD functionality.
  1600.  
  1601. Here is the struct used to define the type @code{bfd}.  This contains
  1602. the major data about the file, and contains pointers to the rest of
  1603. the data.
  1604. */
  1605.  
  1606. struct _bfd 
  1607. {
  1608. /*   The filename the application opened the BFD with.
  1609. */
  1610.  
  1611.   CONST char *filename;                
  1612.  
  1613. /*
  1614. A pointer to the target jump table.
  1615. */
  1616.  
  1617.   struct bfd_target *xvec;
  1618.  
  1619. /*
  1620.  
  1621. To avoid dragging too many header files into every file that
  1622. includes @file{bfd.h}, IOSTREAM has been declared as a "char *", and MTIME
  1623. as a "long".  Their correct types, to which they are cast when used,
  1624. are "FILE *" and "time_t".  
  1625.  
  1626. The iostream is the result of an fopen on the filename.
  1627. */
  1628.  
  1629.   char *iostream;
  1630.  
  1631. /*
  1632. Is the file being cached @xref{File Caching}.
  1633. */
  1634.  
  1635.   boolean cacheable;
  1636.  
  1637. /*
  1638. Marks whether there was a default target specified when the BFD was
  1639. opened. This is used to select what matching algorithm to use to chose
  1640. the back end.
  1641. */
  1642.  
  1643.   boolean target_defaulted;
  1644.  
  1645. /*
  1646. The caching routines use these to maintain a least-recently-used list of
  1647. BFDs (@pxref{File Caching}).
  1648. */
  1649.  
  1650.   struct _bfd *lru_prev, *lru_next;
  1651.  
  1652. /*
  1653. When a file is closed by the caching routines, BFD retains state
  1654. information on the file here:
  1655. */
  1656.  
  1657.   file_ptr where;              
  1658.  
  1659. /*
  1660. and here:
  1661. */
  1662.  
  1663.   boolean opened_once;
  1664.  
  1665. /*
  1666. */
  1667.   boolean mtime_set;
  1668. /* File modified time 
  1669. */
  1670.  
  1671.   long mtime;          
  1672.  
  1673. /*
  1674. Reserved for an unimplemented file locking extension.
  1675. */
  1676.  
  1677. int ifd;
  1678.  
  1679. /*
  1680. The format which belongs to the BFD.
  1681. */
  1682.  
  1683.   bfd_format format;
  1684.  
  1685. /*
  1686. The direction the BFD was opened with
  1687. */
  1688.  
  1689.   enum bfd_direction {no_direction = 0,
  1690.                        read_direction = 1,
  1691.                        write_direction = 2,
  1692.                        both_direction = 3} direction;
  1693.  
  1694. /*
  1695. Format_specific flags
  1696. */
  1697.  
  1698.   flagword flags;              
  1699.  
  1700. /*
  1701. Currently my_archive is tested before adding origin to anything. I
  1702. believe that this can become always an add of origin, with origin set
  1703. to 0 for non archive files.  
  1704. */
  1705.  
  1706.   file_ptr origin;             
  1707.  
  1708. /*
  1709. Remember when output has begun, to stop strange things happening.
  1710. */
  1711.  
  1712.   boolean output_has_begun;
  1713.  
  1714. /*
  1715. Pointer to linked list of sections
  1716. */
  1717.  
  1718.   struct sec  *sections;
  1719.  
  1720. /*
  1721. The number of sections 
  1722. */
  1723.  
  1724.   unsigned int section_count;
  1725.  
  1726. /*
  1727. Stuff only useful for object files:
  1728. The start address.
  1729. */
  1730.  
  1731.   bfd_vma start_address;
  1732. /* Used for input and output
  1733. */
  1734.  
  1735.   unsigned int symcount;
  1736. /* Symbol table for output BFD
  1737. */
  1738.  
  1739.   struct symbol_cache_entry  **outsymbols;             
  1740.  
  1741. /*
  1742. Pointer to structure which contains architecture information
  1743. */
  1744.  
  1745.   struct bfd_arch_info *arch_info;
  1746.  
  1747. /*
  1748. Stuff only useful for archives:
  1749. */
  1750.  
  1751.   PTR arelt_data;              
  1752.   struct _bfd *my_archive;     
  1753.   struct _bfd *next;           
  1754.   struct _bfd *archive_head;   
  1755.   boolean has_armap;           
  1756.  
  1757. /*
  1758. Used by the back end to hold private data.
  1759. */
  1760.  
  1761.   PTR tdata;
  1762.  
  1763. /*
  1764. Used by the application to hold private data
  1765. */
  1766.  
  1767.   PTR usrdata;
  1768.  
  1769. /*
  1770. Where all the allocated stuff under this BFD goes (@pxref{Memory Usage}).
  1771. */
  1772.  
  1773.   struct obstack memory;
  1774. };
  1775.  
  1776. /*
  1777.  
  1778.  bfd_set_start_address
  1779.  
  1780. Marks the entry point of an output BFD. Returns @code{true} on
  1781. success, @code{false} otherwise.
  1782. */
  1783.  
  1784.  PROTO(boolean, bfd_set_start_address,(bfd *, bfd_vma));
  1785.  
  1786. /*
  1787.  
  1788.   bfd_get_mtime
  1789.  
  1790. Return cached file modification time (e.g. as read from archive header
  1791. for archive members, or from file system if we have been called
  1792. before); else determine modify time, cache it, and return it.  
  1793. */
  1794.  
  1795.  PROTO(long, bfd_get_mtime, (bfd *));
  1796.  
  1797. /*
  1798.  
  1799.  stuff
  1800. */
  1801.  
  1802.  
  1803. #define bfd_sizeof_headers(abfd, reloc) \
  1804.      BFD_SEND (abfd, _bfd_sizeof_headers, (abfd, reloc))
  1805.  
  1806. #define bfd_find_nearest_line(abfd, section, symbols, offset, filename_ptr, func, line_ptr) \
  1807.      BFD_SEND (abfd, _bfd_find_nearest_line,  (abfd, section, symbols, offset, filename_ptr, func, line_ptr))
  1808.  
  1809. #define bfd_debug_info_start(abfd) \
  1810.         BFD_SEND (abfd, _bfd_debug_info_start, (abfd))
  1811.  
  1812. #define bfd_debug_info_end(abfd) \
  1813.         BFD_SEND (abfd, _bfd_debug_info_end, (abfd))
  1814.  
  1815. #define bfd_debug_info_accumulate(abfd, section) \
  1816.         BFD_SEND (abfd, _bfd_debug_info_accumulate, (abfd, section))
  1817.  
  1818. #define bfd_stat_arch_elt(abfd, stat) \
  1819.         BFD_SEND (abfd, _bfd_stat_arch_elt,(abfd, stat))
  1820.  
  1821. #define bfd_coff_swap_aux_in(a,e,t,c,i) \
  1822.         BFD_SEND (a, _bfd_coff_swap_aux_in, (a,e,t,c,i))
  1823.  
  1824. #define bfd_coff_swap_sym_in(a,e,i) \
  1825.         BFD_SEND (a, _bfd_coff_swap_sym_in, (a,e,i))
  1826.  
  1827. #define bfd_coff_swap_lineno_in(a,e,i) \
  1828.         BFD_SEND ( a, _bfd_coff_swap_lineno_in, (a,e,i))
  1829.  
  1830. #define bfd_set_arch_mach(abfd, arch, mach)\
  1831.         BFD_SEND ( abfd, _bfd_set_arch_mach, (abfd, arch, mach))
  1832.  
  1833. #define bfd_coff_swap_reloc_out(abfd, i, o) \
  1834.         BFD_SEND (abfd, _bfd_coff_swap_reloc_out, (abfd, i, o))
  1835.  
  1836. #define bfd_coff_swap_lineno_out(abfd, i, o) \
  1837.         BFD_SEND (abfd, _bfd_coff_swap_lineno_out, (abfd, i, o))
  1838.  
  1839. #define bfd_coff_swap_aux_out(abfd, i, t,c,o) \
  1840.         BFD_SEND (abfd, _bfd_coff_swap_aux_out, (abfd, i,t,c, o))
  1841.  
  1842. #define bfd_coff_swap_sym_out(abfd, i,o) \
  1843.         BFD_SEND (abfd, _bfd_coff_swap_sym_out, (abfd, i, o))
  1844.  
  1845. #define bfd_coff_swap_scnhdr_out(abfd, i,o) \
  1846.         BFD_SEND (abfd, _bfd_coff_swap_scnhdr_out, (abfd, i, o))
  1847.  
  1848. #define bfd_coff_swap_filehdr_out(abfd, i,o) \
  1849.         BFD_SEND (abfd, _bfd_coff_swap_filehdr_out, (abfd, i, o))
  1850.  
  1851. #define bfd_coff_swap_aouthdr_out(abfd, i,o) \
  1852.         BFD_SEND (abfd, _bfd_coff_swap_aouthdr_out, (abfd, i, o))
  1853.  
  1854. /*
  1855. */
  1856.  
  1857. /*:archive.c*/
  1858. /* bfd_get_next_mapent
  1859. What this does
  1860. */
  1861.  PROTO(symindex, bfd_get_next_mapent, (bfd *, symindex, carsym **));
  1862.  
  1863. /*
  1864.  
  1865.  bfd_set_archive_head
  1866.  
  1867. Used whilst processing archives. Sets the head of the chain of BFDs
  1868. contained in an archive to @var{new_head}. (see chapter on archives)
  1869. */
  1870.  
  1871.  PROTO(boolean, bfd_set_archive_head, (bfd *output, bfd *new_head));
  1872.  
  1873. /*
  1874.  
  1875.  bfd_get_elt_at_index
  1876. Return the sub bfd contained within the archive at archive index n.
  1877. */
  1878.  
  1879.  PROTO(bfd *, bfd_get_elt_at_index, (bfd *, int));
  1880.  
  1881. /*
  1882.  
  1883.  bfd_openr_next_archived_file
  1884. Initially provided a BFD containing an archive and NULL, opens a BFD
  1885. on the first contained element and returns that. Subsequent calls to
  1886. bfd_openr_next_archived_file should pass the archive and the previous
  1887. return value to return a created BFD to the next contained element.
  1888. NULL is returned when there are no more.
  1889. */
  1890.  
  1891.  PROTO(bfd*, bfd_openr_next_archived_file,
  1892.                (bfd *archive, bfd *previous));
  1893.  
  1894. /*
  1895. */
  1896.  
  1897.  
  1898. /*:core.c*/
  1899. /* bfd_core_file_failing_command
  1900. Returns a read-only string explaining what program was running when
  1901. it failed and produced the core file being read
  1902. */
  1903.  
  1904.  PROTO(CONST char *, bfd_core_file_failing_command, (bfd *));
  1905.  
  1906. /*
  1907.  
  1908.  bfd_core_file_failing_signal
  1909. Returns the signal number which caused the core dump which generated
  1910. the file the BFD is attached to.
  1911. */
  1912.  
  1913.  PROTO(int, bfd_core_file_failing_signal, (bfd *));
  1914.  
  1915. /*
  1916.  
  1917.  core_file_matches_executable_p
  1918. Returns @code{true} if the core file attached to @var{core_bfd} was
  1919. generated by a run of the executable file attached to @var{exec_bfd},
  1920. or else @code{false}.
  1921. */
  1922.  PROTO(boolean, core_file_matches_executable_p,
  1923.     (bfd *core_bfd, bfd *exec_bfd));
  1924.  
  1925. /*
  1926. */
  1927.  
  1928. /*:targets.c*/
  1929. /* bfd_target
  1930. @node bfd_target,  , Targets, Targets
  1931. @subsection bfd_target
  1932. This structure contains everything that BFD knows about a target.
  1933. It includes things like its byte order, name, what routines to call
  1934. to do various operations, etc.   
  1935.  
  1936. Every BFD points to a target structure with its "xvec" member. 
  1937.  
  1938. Shortcut for declaring fields which are prototyped function pointers,
  1939. while avoiding anguish on compilers that don't support protos.
  1940. */
  1941.  
  1942. #define SDEF(ret, name, arglist) \
  1943.                 PROTO(ret,(*name),arglist)
  1944. #define SDEF_FMT(ret, name, arglist) \
  1945.                 PROTO(ret,(*name[bfd_type_end]),arglist)
  1946.  
  1947. /*
  1948. These macros are used to dispatch to functions through the bfd_target
  1949. vector. They are used in a number of macros further down in @file{bfd.h}, and
  1950. are also used when calling various routines by hand inside the BFD
  1951. implementation.  The "arglist" argument must be parenthesized; it
  1952. contains all the arguments to the called function.
  1953. */
  1954.  
  1955. #define BFD_SEND(bfd, message, arglist) \
  1956.                ((*((bfd)->xvec->message)) arglist)
  1957.  
  1958. /*
  1959. For operations which index on the BFD format 
  1960. */
  1961.  
  1962. #define BFD_SEND_FMT(bfd, message, arglist) \
  1963.             (((bfd)->xvec->message[(int)((bfd)->format)]) arglist)
  1964.  
  1965. /*
  1966. This is the struct which defines the type of BFD this is.  The
  1967. "xvec" member of the struct @code{bfd} itself points here.  Each module
  1968. that implements access to a different target under BFD, defines
  1969. one of these.
  1970.  
  1971. FIXME, these names should be rationalised with the names of the
  1972. entry points which call them. Too bad we can't have one macro to
  1973. define them both! 
  1974. */
  1975.  
  1976. typedef struct bfd_target
  1977. {
  1978.  
  1979. /*
  1980. identifies the kind of target, eg SunOS4, Ultrix, etc 
  1981. */
  1982.  
  1983.   char *name;
  1984.  
  1985. /*
  1986. The "flavour" of a back end is a general indication about the contents
  1987. of a file.
  1988. */
  1989.  
  1990.   enum target_flavour {
  1991.     bfd_target_unknown_flavour,
  1992.     bfd_target_aout_flavour,
  1993.     bfd_target_coff_flavour,
  1994.     bfd_target_elf_flavour,
  1995.     bfd_target_ieee_flavour,
  1996.     bfd_target_oasys_flavour,
  1997.     bfd_target_srec_flavour} flavour;
  1998.  
  1999. /*
  2000. The order of bytes within the data area of a file.
  2001. */
  2002.  
  2003.   boolean byteorder_big_p;
  2004.  
  2005. /*
  2006. The order of bytes within the header parts of a file.
  2007. */
  2008.  
  2009.   boolean header_byteorder_big_p;
  2010.  
  2011. /*
  2012. This is a mask of all the flags which an executable may have set -
  2013. from the set @code{NO_FLAGS}, @code{HAS_RELOC}, ...@code{D_PAGED}.
  2014. */
  2015.  
  2016.   flagword object_flags;       
  2017.  
  2018. /*
  2019. This is a mask of all the flags which a section may have set - from
  2020. the set @code{SEC_NO_FLAGS}, @code{SEC_ALLOC}, ...@code{SET_NEVER_LOAD}.
  2021. */
  2022.  
  2023.   flagword section_flags;
  2024.  
  2025. /*
  2026. The pad character for filenames within an archive header.
  2027. */
  2028.  
  2029.   char ar_pad_char;            
  2030.  
  2031. /*
  2032. The maximum number of characters in an archive header.
  2033. */
  2034.  
  2035.  unsigned short ar_max_namelen;
  2036.  
  2037. /*
  2038. The minimum alignment restriction for any section.
  2039. */
  2040.  
  2041.   unsigned int align_power_min;
  2042.  
  2043. /*
  2044. Entries for byte swapping for data. These are different to the other
  2045. entry points, since they don't take BFD as first arg.  Certain other handlers
  2046. could do the same.
  2047. */
  2048.  
  2049.   SDEF (bfd_vma,      bfd_getx64, (bfd_byte *));
  2050.   SDEF (void,         bfd_putx64, (bfd_vma, bfd_byte *));
  2051.   SDEF (bfd_vma, bfd_getx32, (bfd_byte *));
  2052.   SDEF (void,         bfd_putx32, (bfd_vma, bfd_byte *));
  2053.   SDEF (bfd_vma, bfd_getx16, (bfd_byte *));
  2054.   SDEF (void,         bfd_putx16, (bfd_vma, bfd_byte *));
  2055.  
  2056. /*
  2057. Byte swapping for the headers
  2058. */
  2059.  
  2060.   SDEF (bfd_vma,   bfd_h_getx64, (bfd_byte *));
  2061.   SDEF (void,          bfd_h_putx64, (bfd_vma, bfd_byte *));
  2062.   SDEF (bfd_vma,  bfd_h_getx32, (bfd_byte *));
  2063.   SDEF (void,          bfd_h_putx32, (bfd_vma, bfd_byte *));
  2064.   SDEF (bfd_vma,  bfd_h_getx16, (bfd_byte *));
  2065.   SDEF (void,          bfd_h_putx16, (bfd_vma, bfd_byte *));
  2066.  
  2067. /*
  2068. Format dependent routines, these turn into vectors of entry points
  2069. within the target vector structure; one for each format to check.
  2070.  
  2071. Check the format of a file being read.  Return bfd_target * or zero. 
  2072. */
  2073.  
  2074.   SDEF_FMT (struct bfd_target *, _bfd_check_format, (bfd *));
  2075.  
  2076. /*
  2077. Set the format of a file being written.  
  2078. */
  2079.  
  2080.   SDEF_FMT (boolean,            _bfd_set_format, (bfd *));
  2081.  
  2082. /*
  2083. Write cached information into a file being written, at bfd_close. 
  2084. */
  2085.  
  2086.   SDEF_FMT (boolean,            _bfd_write_contents, (bfd *));
  2087.  
  2088. /*
  2089. The following functions are defined in @code{JUMP_TABLE}. The idea is
  2090. that the back end writer of @code{foo} names all the routines
  2091. @code{foo_}@var{entry_point}, @code{JUMP_TABLE} will built the entries
  2092. in this structure in the right order.
  2093.  
  2094. Core file entry points
  2095. */
  2096.  
  2097.   SDEF (char *, _core_file_failing_command, (bfd *));
  2098.   SDEF (int,    _core_file_failing_signal, (bfd *));
  2099.   SDEF (boolean, _core_file_matches_executable_p, (bfd *, bfd *));
  2100.  
  2101. /*
  2102. Archive entry points
  2103. */
  2104.  
  2105.  SDEF (boolean, _bfd_slurp_armap, (bfd *));
  2106.  SDEF (boolean, _bfd_slurp_extended_name_table, (bfd *));
  2107.  SDEF (void,   _bfd_truncate_arname, (bfd *, CONST char *, char *));
  2108.  SDEF (boolean, write_armap, (bfd *arch, 
  2109.                               unsigned int elength,
  2110.                               struct orl *map,
  2111.                               int orl_count, 
  2112.                               int stridx));
  2113.  
  2114. /*
  2115. Standard stuff.
  2116. */
  2117.  
  2118.   SDEF (boolean, _close_and_cleanup, (bfd *));
  2119.   SDEF (boolean, _bfd_set_section_contents, (bfd *, sec_ptr, PTR,
  2120.                                             file_ptr, bfd_size_type));
  2121.   SDEF (boolean, _bfd_get_section_contents, (bfd *, sec_ptr, PTR, 
  2122.                                             file_ptr, bfd_size_type));
  2123.   SDEF (boolean, _new_section_hook, (bfd *, sec_ptr));
  2124.  
  2125. /*
  2126. Symbols and reloctions
  2127. */
  2128.  
  2129.  SDEF (unsigned int, _get_symtab_upper_bound, (bfd *));
  2130.   SDEF (unsigned int, _bfd_canonicalize_symtab,
  2131.            (bfd *, struct symbol_cache_entry **));
  2132.   SDEF (unsigned int, _get_reloc_upper_bound, (bfd *, sec_ptr));
  2133.   SDEF (unsigned int, _bfd_canonicalize_reloc, (bfd *, sec_ptr, arelent **,
  2134.                                                struct symbol_cache_entry**));
  2135.   SDEF (struct symbol_cache_entry  *, _bfd_make_empty_symbol, (bfd *));
  2136.   SDEF (void,     _bfd_print_symbol, (bfd *, PTR, struct symbol_cache_entry  *,
  2137.                                       bfd_print_symbol_type));
  2138. #define bfd_print_symbol(b,p,s,e) BFD_SEND(b, _bfd_print_symbol, (b,p,s,e))
  2139.   SDEF (alent *,   _get_lineno, (bfd *, struct symbol_cache_entry  *));
  2140.  
  2141.   SDEF (boolean,   _bfd_set_arch_mach, (bfd *, enum bfd_architecture,
  2142.                                        unsigned long));
  2143.  
  2144.   SDEF (bfd *,  openr_next_archived_file, (bfd *arch, bfd *prev));
  2145.   SDEF (boolean, _bfd_find_nearest_line,
  2146.         (bfd *abfd, struct sec  *section,
  2147.          struct symbol_cache_entry  **symbols,bfd_vma offset,
  2148.         CONST char **file, CONST char **func, unsigned int *line));
  2149.   SDEF (int,    _bfd_stat_arch_elt, (bfd *, struct stat *));
  2150.  
  2151.   SDEF (int,    _bfd_sizeof_headers, (bfd *, boolean));
  2152.  
  2153.   SDEF (void, _bfd_debug_info_start, (bfd *));
  2154.   SDEF (void, _bfd_debug_info_end, (bfd *));
  2155.   SDEF (void, _bfd_debug_info_accumulate, (bfd *, struct sec  *));
  2156.  
  2157. /*
  2158. Special entry points for gdb to swap in coff symbol table parts
  2159. */
  2160.  
  2161.   SDEF(void, _bfd_coff_swap_aux_in,(
  2162.        bfd            *abfd ,
  2163.        PTR             ext,
  2164.        int             type,
  2165.        int             class ,
  2166.        PTR             in));
  2167.  
  2168.   SDEF(void, _bfd_coff_swap_sym_in,(
  2169.        bfd            *abfd ,
  2170.        PTR             ext,
  2171.        PTR             in));
  2172.  
  2173.   SDEF(void, _bfd_coff_swap_lineno_in,  (
  2174.        bfd            *abfd,
  2175.        PTR            ext,
  2176.        PTR             in));
  2177.  
  2178. /*
  2179. Special entry points for gas to swap coff parts
  2180. */
  2181.  
  2182.  SDEF(unsigned int, _bfd_coff_swap_aux_out,(
  2183.        bfd       *abfd,
  2184.        PTR    in,
  2185.        int        type,
  2186.        int        class,
  2187.        PTR        ext));
  2188.  
  2189.  SDEF(unsigned int, _bfd_coff_swap_sym_out,(
  2190.       bfd      *abfd,
  2191.       PTR    in,
  2192.       PTR    ext));
  2193.  
  2194.  SDEF(unsigned int, _bfd_coff_swap_lineno_out,(
  2195.           bfd       *abfd,
  2196.           PTR    in,
  2197.     PTR    ext));
  2198.  
  2199.  SDEF(unsigned int, _bfd_coff_swap_reloc_out,(
  2200.           bfd     *abfd,
  2201.          PTR    src,
  2202.     PTR    dst));
  2203.  
  2204.  SDEF(unsigned int, _bfd_coff_swap_filehdr_out,(
  2205.           bfd      *abfd,
  2206.     PTR     in,
  2207.     PTR     out));
  2208.  
  2209.  SDEF(unsigned int, _bfd_coff_swap_aouthdr_out,(
  2210.           bfd     *abfd,
  2211.     PTR     in,
  2212.     PTR    out));
  2213.  
  2214.  SDEF(unsigned int, _bfd_coff_swap_scnhdr_out,(
  2215.           bfd      *abfd,
  2216.           PTR    in,
  2217.     PTR    out));
  2218.  
  2219. } bfd_target;
  2220.  
  2221. /*
  2222.  
  2223. *i bfd_find_target
  2224. Returns a pointer to the transfer vector for the object target
  2225. named target_name.  If target_name is NULL, chooses the one in the
  2226. environment variable GNUTARGET; if that is null or not defined then
  2227. the first entry in the target list is chosen.  Passing in the
  2228. string "default" or setting the environment variable to "default"
  2229. will cause the first entry in the target list to be returned,
  2230. and "target_defaulted" will be set in the BFD.  This causes
  2231. @code{bfd_check_format} to loop over all the targets to find the one
  2232. that matches the file being read.  
  2233. */
  2234.  PROTO(bfd_target *, bfd_find_target,(CONST char *, bfd *));
  2235.  
  2236. /*
  2237.  
  2238. *i bfd_target_list
  2239. This function returns a freshly malloced NULL-terminated vector of the
  2240. names of all the valid BFD targets. Do not modify the names 
  2241. */
  2242.  PROTO(CONST char **,bfd_target_list,());
  2243.  
  2244. /*
  2245. */
  2246.  
  2247.  
  2248. /*:format.c*/
  2249. /* *i bfd_check_format
  2250. This routine is supplied a BFD and a format. It attempts to verify if
  2251. the file attached to the BFD is indeed compatible with the format
  2252. specified (ie, one of @code{bfd_object}, @code{bfd_archive} or
  2253. @code{bfd_core}).
  2254.  
  2255. If the BFD has been set to a specific @var{target} before the call,
  2256. only the named target and format combination will be checked. If the
  2257. target has not been set, or has been set to @code{default} then all
  2258. the known target backends will be interrogated to determine a match.
  2259.  
  2260. The function returns @code{true} on success, otherwise @code{false}
  2261. with one of the following error codes: 
  2262. @table @code
  2263. @item 
  2264. invalid_operation
  2265. if @code{format} is not one of @code{bfd_object}, @code{bfd_archive}
  2266. or @code{bfd_core}.
  2267. @item system_call_error
  2268. if an error occured during a read -  even some file mismatches can
  2269. cause system_call_errros
  2270. @item file_not_recognised
  2271. none of the backends recognised the file format
  2272. @item file_ambiguously_recognized
  2273. more than one backend recognised the file format.
  2274. @end table
  2275. */
  2276.  PROTO(boolean, bfd_check_format, (bfd *abfd, bfd_format format));
  2277.  
  2278. /*
  2279.  
  2280. *i bfd_set_format
  2281. This function sets the file format of the supplied BFD to the format
  2282. requested. If the target set in the BFD does not support the format
  2283. requested, the format is illegal or the BFD is not open for writing
  2284. than an error occurs.
  2285. */
  2286.  PROTO(boolean,bfd_set_format,(bfd *, bfd_format));
  2287.  
  2288. /*
  2289.  
  2290. *i bfd_format_string
  2291. This function takes one argument, and enumerated type (bfd_format) and
  2292. returns a pointer to a const string "invalid", "object", "archive",
  2293. "core" or "unknown" depending upon the value of the enumeration.
  2294. */
  2295.  PROTO(CONST char *, bfd_format_string, (bfd_format));
  2296.  
  2297. /*
  2298. */
  2299.  
  2300. #endif
  2301.  
  2302.  
  2303.  
  2304.  
  2305.  
  2306.